# **Bluetrum Technology**

# **BT8812**

# Audio Player Microcontroller User Manual

Versions: 0.0.3

2018/09/28

### **Declaration**

Copyright © 2018, www. bluetrum.com.

All Rights Reserved. No Unauthorized Distribution.

Bluetrum reserves the right to make changes without further notice to any products herein to improve reliability, function or design.

For further information on the technology, product and business term, please contact Bluetrum Company.

For sales or technical support, please send email to the address:

Sales: sales@bluetrum.com

Technical: project@bluetrum.com

# **Bluetrum Technology**

### Appendix I Revision History

| Date       | Version | Comments                     | Revised by |
|------------|---------|------------------------------|------------|
| 2018-08-21 | 0.0.1   | First draft                  | Leo        |
| 2018-09-11 | 0.0.2   | Update uart0baud description | Leo        |
| 2018-09-28 | 0.0.3   | Remove package               | Leo        |
|            |         |                              |            |
|            |         |                              |            |
|            |         |                              |            |
|            |         |                              |            |

# **Table of Contents**

| IAB | BLE OF CONTENTS                       | 3  |
|-----|---------------------------------------|----|
| 1   | PRODUCT OVERVIEW                      | 5  |
| 1.1 | Introduce                             | 5  |
| 1.2 | FEATURES                              | 6  |
| 2   | INTERRUPTS                            | 7  |
| 2.1 | Interrupts Special Registers          | 8  |
| 3   | GPIO MANAGEMENT                       | 9  |
| 3.1 | FEATURES                              | 9  |
| 3.2 | GPIO GENERAL CONTROL REGISTER         | 9  |
| 3.3 | GPIO FUNCTION MAPPING                 | 11 |
| 3.4 | EXTERNAL PORT INTERRUPT WAKE UP       | 13 |
| 4   | TIMER                                 | 15 |
| 4.1 | FEATURES                              | 15 |
| 4.2 | TIMERO/1/2 SPECIAL FUNCTION REGISTERS | 15 |
| 4.3 | TIMER3/4/5 SPECIAL FUNCTION REGISTERS | 16 |
| 5   | PWM                                   | 18 |
| 5.1 | FEATURES                              | 18 |
| 5.2 | Special Function Registers            | 18 |
| 6   | RTC                                   | 20 |
| 6.1 | FEATURES                              | 20 |
| 6.2 | Special Function Registers            | 20 |
| 6.3 | Independent Power RTC Registers       | 21 |
| 7   | UART0                                 | 25 |
| 7.1 | FEATURES                              | 25 |
| 7.2 | UARTO SPECIAL FUNCTION REGISTERS      | 25 |
| 7.3 | User Guide                            | 26 |
| 8   | SPI0                                  | 27 |
| 8.1 | FEATURES                              | 27 |
| 9   | CHARACTERISTICS                       | 28 |
| 9.1 | PMU PARAMETERS                        | 28 |
| 9.2 | IO Parameters                         | 28 |
| 9.3 | AUDIO DAC PARAMETERS                  | 29 |

### Table of content

| 9.4 | AUDIO ADC PARAMETERS | 29 |
|-----|----------------------|----|
| 9.5 | BT Parameters        | 29 |
| 9.6 | CURRENT PARAMETERS   | 30 |

1Product Overview 5

# **1 Product Overview**

### 1.1 Introduce

BT8812 is a 32 bits RISC microcontroller. It integrates advanced digital and analog peripherals to audio player applications.



1 6

### 1.2 Features

### **CPU and Flexible IO**

- 32bit High performance CPU with DSP instruction
- Flexible GPIO pins with Programmable pull-up and pull-down resistors;
- Support GPIO wakeup or interrupt;

### **Bluetooth Radio**

- Compliant to Bluetooth 5.0 and BLE specification (QDID: <u>115952</u>);
- ◆ TX output power +2db in typical;
- RX Sensitivity with -90.5dBm @Basic Rate;

#### **FM Tuner**

- Support frequency band 76~108MHz;
- Auto search tuning;
- Programable de-emphasis(50/75uS);
- Receive signal strength indicator (RSSI);

#### **Audio Interface**

- Audio codec with 16bit stereo DAC and two channel 16bit ADC;
- Support flexible audio EQ adjust;
- Support Sample rate 8, 11.025, 12, 16, 22.05, 32, 44.1 and 48KHz;
- 4 channel Stereo Analog MUX;
- Two channel MIC amplifier input;
- High performance Stereo audio ADC with 90dB SNR;
- High performance Stereo audio DAC with

95dB SNR, with headphone amplifier output;

### **Peripheral and Interfaces**

- Three 32-bit timers;
- Three multi-function 32-bit timers, support Capture and PWM mode;
- WatchDog;
- Three full-duplex UART;
- Two SPI;
- ♣ IR controller;
- SD Card Host controller;
- SPDIF receiver;
- Full speed USB 2.0 HOST/DEVICE controller;
- Sixteen Channels 10-bit SARADC;
- Integrate IRTC;
- Build in PMU, such as charger/buck/LDO;

### **Package**

QFN32L;

### **Temperature**

- $\blacksquare$  Operating temperature: -40°C to +85°C;
- **♣** Storage temperature: -65°C to +150°C;

2Interrupts 7

# 2 Interrupts

Support vectorized interrupts, exceptions on illegal instructions and exceptions on load and store instructions to invalid addresses.

### **Exception vectors**

| Interrupt<br>number | Address    | Description                                      |
|---------------------|------------|--------------------------------------------------|
| 0                   | 0x00       | Reset                                            |
| 1                   | 0x10       |                                                  |
| 2                   | 0x20       |                                                  |
| 3                   | 0x30       |                                                  |
| 4                   | 0x40       | Low priority interrupt                           |
| 5                   | 0x50       |                                                  |
| 6                   | 0x60       |                                                  |
| 7                   | 0x70       |                                                  |
| 8                   | 0x80~0x280 | High priority interrupt(see the following table) |

### **High priority interrupt vectors**

|                     |         | rupt vectors          |
|---------------------|---------|-----------------------|
| Interrupt<br>number | Address | Description           |
| 0                   | 0x80    |                       |
| 1                   | 0x90    |                       |
| 2                   | 0xa0    | Software interrupt    |
| 3                   | 0xb0    | Timer0 interrupt      |
| 4                   | 0xc0    | Timer1 interrupt      |
|                     |         | Timer2 interrupt      |
| 5                   | 0xd0    | Timer4 interrupt      |
|                     |         | Timer5 interrupt      |
| 6                   | 0xe0    | Timer3 interrupt      |
| 6                   | uxeu    | IR receiver interrupt |
| 7                   | 0xf0    |                       |
| 8                   | 0x100   |                       |
| 9                   | 0x110   |                       |
| 10                  | 0x120   |                       |
| 11                  | 0x130   |                       |
| 12                  | 0x140   |                       |
| 13                  | 0x150   |                       |
|                     |         | UART0 interrupt       |
| 14                  | 0x160   | UART1 interrupt       |
|                     |         | UART2 interrupt       |
| 15                  | 0x170   |                       |
| 16                  | 0x180   |                       |
| 17                  | 0x190   |                       |
| 18                  | 0x1a0   | Port interrupt        |
| 19                  | 0x1b0   |                       |
| 20                  | 0x1c0   |                       |
| 21                  | 0x1d0   |                       |
| 22                  | 0x1e0   |                       |
| 23                  | 0x1f0   |                       |
| 24                  | 0x200   |                       |
| 25                  | 0x210   |                       |
| 26                  | 0x220   |                       |
| 27                  | 0x230   |                       |
| 28                  | 0x240   |                       |
| 29                  | 0x250   |                       |

2Interrupts 8

| Interrupt<br>number | Address | Description |
|---------------------|---------|-------------|
| 30                  | 0x260   |             |
| 31                  | 0x270   |             |

# 2.1 Interrupts Special Registers

### Register 2-1PICCON: Peripheral interrupt control Register

| Bit   | Name    | Mode | Default | Description                        |
|-------|---------|------|---------|------------------------------------|
| 31:17 | -       | -    | -       | Unused                             |
|       |         |      |         | Global interrupt enable mask bit   |
| 16    | GIEM    | WR   | 1       | 0: disable interrupt               |
|       |         |      |         | 1: enable interrupt                |
| 15:8  | -       | -    | -       | Unused                             |
| 7:3   | -       | -    | -       | Unused                             |
|       |         |      |         | High priority interrupt enable bit |
| 2     | HPINTEN | WR   | 0       | 0: disable                         |
|       |         |      |         | 1: enable                          |
|       |         |      |         | Low priority interrupt enable bit  |
| 1     | LPINTEN | WR   | 0       | 0: disable                         |
|       |         |      |         | 1: enable                          |
|       |         |      |         | Global interrupt enable bit        |
| 0     | GIE     | WR   | 0       | 0: disable interrupt               |
|       |         |      |         | 1: enable interrupt                |

### Register 2-2PICCONSET: Peripheral interrupt control set Register

| Bit   | Name    | Mode | Default | Description                                 |
|-------|---------|------|---------|---------------------------------------------|
| 31:17 | -       | -    | -       | Unused                                      |
| 16    | GIEM    | W    | 0       | Write 1 enable Global interrupt enable mask |
| 15:8  | -       | -    | -       | Unused                                      |
| 7:3   | -       | -    | -       | Unused                                      |
| 2     | HPINTEN | W    | 0       | Write 1 enable High priority interrupt      |
| 1     | LPINTEN | W    | 0       | Write 1 enable Low priority interrupt       |
| 0     | GIE     | W    | 0       | Write 1 enable Global interrupt             |

### Register 2-3PICCONCLR: Peripheral interrupt control clear Register

| Bit   | Name     | Mode | Default | Description                                  |
|-------|----------|------|---------|----------------------------------------------|
| 31:17 | -        | -    | -       | Unused                                       |
| 16    | GIEMDIS  | W    | 0       | Write 1 disable Global interrupt enable mask |
| 15:8  | -        | -    | -       | Unused                                       |
| 7:3   | -        | -    | -       | Unused                                       |
| 2     | HPINTDIS | W    | 0       | Write 1 disable High priority interrupt      |
| 1     | LPINTDIS | W    | 0       | Write 1 disable Low priority interrupt       |
| 0     | GIEDIS   | W    | 0       | Write 1 disable Global interrupt             |

### Register 2-4PICEN: Peripheral interrupt enable Register

| Bit  | Name  | Mode | Default | Description                  |
|------|-------|------|---------|------------------------------|
|      |       |      |         | Interrupt 31 to 0 enable bit |
| 31:0 | IntEN | WR   | 0x0     | 0: disable                   |
|      |       |      |         | 1: enable                    |

### Register 2-5PICENSET: Peripheral interrupt enable set Register

| Bit  | Name  | Mode | Default | Description                      |
|------|-------|------|---------|----------------------------------|
| 31:0 | IntEN | W    | 0x0     | Write 1 enable Interrupt 31 to 0 |

### Register 2-6PICENCLR: Peripheral interrupt enable clear Register

| Bit  | Name   | Mode | Default | Description                       |
|------|--------|------|---------|-----------------------------------|
| 31:0 | IntDIS | W    | 0x0     | Write 1 disable Interrupt 31 to 0 |

### Register 2-7PICPR: Peripheral high priority interrupt selection Register

| Bit  | Name  | Mode | Default | Description                              |
|------|-------|------|---------|------------------------------------------|
|      |       |      |         | Interrupt 31 to 0 priority selection bit |
| 31:0 | IntPR | WR   | 0x0     | 0: low priority interrupt                |
|      |       |      |         | 1: high priority interrupt               |

#### Register 2-8PICADR: Peripheral interrupt address Register

| Bit   | Name | Mode | Default | Description             |
|-------|------|------|---------|-------------------------|
| 31:10 | BADR | WR   | 0x40    | Interrupt entry address |
| 9:0   | -    | -    | 0x0     |                         |

### Register 2-9PICPND: Peripheral interrupt pending Register

| Bit  | Name         | Mode | Default | Description                                                               |
|------|--------------|------|---------|---------------------------------------------------------------------------|
|      |              |      |         | Interrupt 31 to 4 pending bit                                             |
| 31:3 | IntPND[31:4] | R    | 0x0     | 0: no interrupt pending                                                   |
|      |              |      |         | 1: interrupt pending                                                      |
| 2    | SWIPND       | WR   | 0       | Software interrupt pending. Write 1 will clear software interrupt pending |
|      |              |      |         | Interrupt 2 to 0 pending bit                                              |
| 1:0  | IntPND[2:0]  | R    | 0x0     | 0: no interrupt pending                                                   |
|      |              |      |         | 1: interrupt pending                                                      |

# **3 GPIO Management**

### 3.1 Features

- 1. Control GPIO input/output direction by using direction register;
- 2. Internal pull-up/pull-down resistor by using pull-up/pull-down resistor control register;
- 3. Select suitable output driving current capability;

### 3.2 GPIO general control register

### Register 3-1GPIOA: Port A data Register

| Bit  | Name  | Mode | Default | Description                                                           |
|------|-------|------|---------|-----------------------------------------------------------------------|
| 31:8 | -     | -    | -       | Unused                                                                |
|      |       |      |         | PAx data. Valid when PAx is used as GPIO                              |
| 7:0  | GPIOA | WR   | 0x00    | 0: PAx is input low state when read and output low at PAx when write; |
|      |       |      |         | 1:PAx is input high state when read and output high at PAx when write |

#### Register 3-2GPIOASET: Port A Set output data Register

| Bit  | Name     | Mode | Default | Description                                                           |
|------|----------|------|---------|-----------------------------------------------------------------------|
| 31:8 | -        | -    | •       | Unused                                                                |
| 7:0  | GPIOASET | WO   | Χ       | Set Pax output data. Write 1 set output data. Write 0 affect nothing. |

#### Register 3-3GPIOACLR: Port A clear output data Register

| Bit  | Name     | Mode | Default | Description                                                               |
|------|----------|------|---------|---------------------------------------------------------------------------|
| 31:8 | -        | -    |         | Unused                                                                    |
| 7:0  | GPIOACLR | WO   | Χ       | Clear Pax output data. Write 1 clear output data. Write 0 affect nothing. |

#### Register 3-4GPIOADIR: Port A direction Register

| Bit  | Name     | Mode | Default | Description           |
|------|----------|------|---------|-----------------------|
| 31:8 | -        | -    | -       | Unused                |
|      |          |      |         | PAx direction control |
| 7:0  | GPIOADIR | WR   | 0xFF    | 0: Output             |
|      |          |      |         | 1: Input              |

### Register 3-5GPIOAPU: Port A pull-up Register

| Bit  | Name    | Mode | Default | Description                                                        |
|------|---------|------|---------|--------------------------------------------------------------------|
| 31:8 | -       | -    | -       | Unused                                                             |
|      |         |      |         | PAx 10KΩ pull-up resister control. Valid when PAx is used as input |
| 7:0  | GPIOAPU | WR   | 0x0     | 0: disable                                                         |
|      |         |      |         | 1: enable                                                          |

### Register 3-6GPIOAPD: Port A pull-down resister Register

| Bit  | Name    | Mode | Default | Description                                                          |
|------|---------|------|---------|----------------------------------------------------------------------|
| 31:8 | -       | -    | -       | Unused                                                               |
|      |         |      |         | PAx 10KΩ pull-down resister control. Valid when PAx is used as input |
| 7:0  | GPIOAPD | WR   | 0x0     | 0: disable                                                           |
|      |         |      |         | 1: enable                                                            |

#### Register 3-7GPIOAPU200K: Port A pull-up resister Register

| Bit  | Name    | Mode | Default | Description                                                         |
|------|---------|------|---------|---------------------------------------------------------------------|
| 31:8 | -       | -    | -       | Unused                                                              |
|      |         |      |         | PAx 200KΩ pull-up resister control. Valid when PAx is used as input |
| 7:0  | GPIOAPU | WR   | 0x0     | 0: disable                                                          |
|      |         |      |         | 1: enable                                                           |

### Register 3-8GPIOAPD200K: Port A pull-down resister Register

| Bit  | Name    | Mode | Default | Description                                                           |
|------|---------|------|---------|-----------------------------------------------------------------------|
| 31:8 | -       | -    | -       | Unused                                                                |
|      |         |      |         | PAx 200KΩ pull-down resister control. Valid when PAx is used as input |
| 7:0  | GPIOAPD | WR   | 0x0     | 0: disable                                                            |
|      |         |      |         | 1: enable                                                             |

### Register 3-9GPIOAPU300: Port A pull-up resister Register

| Bit  | Name    | Mode | Default | Description                                                        |
|------|---------|------|---------|--------------------------------------------------------------------|
| 31:8 | -       | -    | -       | Unused                                                             |
|      |         |      |         | PAx 300Ω pull-up resister control. Valid when PAx is used as input |
| 7:0  | GPIOAPU | WR   | 0x0     | 0: disable                                                         |
|      |         |      |         | 1: enable                                                          |

### Register 3-10GPIOAPD300: Port A pull-down resister Register

|      |         | •    |         |                                                                      |
|------|---------|------|---------|----------------------------------------------------------------------|
| Bit  | Name    | Mode | Default | Description                                                          |
| 31:8 | -       | -    | -       | Unused                                                               |
|      |         |      |         | PAx 300Ω pull-down resister control. Valid when PAx is used as input |
| 7:0  | GPIOAPD | WR   | 0x0     | 0: disable                                                           |
|      |         |      |         | 1: enable                                                            |

#### Register 3-11GPIOADE: Port A digital function enable register

| •    |         | U    |         | 3                           |
|------|---------|------|---------|-----------------------------|
| Bit  | Name    | Mode | Default | Description                 |
| 31:8 | -       | -    | -       | Unused                      |
|      |         |      |         | PAx digital function enable |
| 7:0  | GPIOADE | WR   | 0xFF    | 0: Port used as analog IO   |
|      |         |      |         | 1: Port used as digital IO  |

### Register 3-12GPIOAFEN: Port A function mapping enable register

| В | 14   | Name | Mode | Default | Description |
|---|------|------|------|---------|-------------|
| В | oit. | Name | woue | Delault | Description |

| Bit  | Name     | Mode | Default | Description                 |
|------|----------|------|---------|-----------------------------|
| 31:8 | -        | -    | -       | Unused                      |
|      |          |      |         | PAx function mapping enable |
| 7:0  | GPIOAFEN | WR   | 0xFF    | 0: Port used as GPIO        |
|      |          |      |         | 1: Port used as function IO |

### Register 3-13GPIOADRV: Port A output driving select Register

| Bit  | Name     | Mode | Default | Description               |
|------|----------|------|---------|---------------------------|
| 31:8 | -        | -    | -       | Unused                    |
|      |          |      |         | PAx output driving select |
| 7:0  | GPIOADRV | WR   | 0x0     | 0: 8mA                    |
|      |          |      |         | 1: 32mA                   |

# 3.3 GPIO function mapping

Register 3-14FUNCMCON0: Port function mapping control Register 0

| Bit   | Name        | Mode | Default | Description                            |
|-------|-------------|------|---------|----------------------------------------|
|       |             |      |         | UART1 RX mapping                       |
|       |             |      |         | 0000: no affect                        |
|       |             |      |         | 0001: map to G1                        |
| 31:28 | UT1RXMAP    | WR   | 0x0     | 0010: map to G2                        |
|       |             |      |         | 0011: map to TX pin by UT1TXMAP select |
|       |             |      |         | 1111: Clear these bits                 |
|       |             |      |         | Others is reserved                     |
|       |             |      |         | UART1 TX mapping                       |
|       |             |      |         | 0000: no affect                        |
| 07.04 | LITATIVAAAD | 14/D |         | 0001: map to G1                        |
| 27:24 | UT1TXMAP    | WR   | 0x0     | 0010: map to G2                        |
|       |             |      |         | 1111: Clear these bits                 |
|       |             |      |         | Others is reserved                     |
| 23:20 |             |      |         |                                        |
| 19:16 |             |      |         |                                        |
|       |             |      |         | UARTO RX mapping                       |
|       |             |      |         | 0000: no affect                        |
|       |             |      |         | 0001: map to G1                        |
|       |             |      |         | 0010: map to G2                        |
|       |             |      |         | 0011: map to G3                        |
| 15:12 | UT0RXMAP    | WR   | 0x0     | 0100: map to G4                        |
|       |             |      |         | 0101: map to G5                        |
|       |             |      |         | 0110: map to G6                        |
|       |             |      |         | 0111: map to TX pin by UT0TXMAP select |
|       |             |      |         | 1111: Clear these bits                 |
|       |             |      |         | Others is reserved                     |
|       |             |      |         | UART0 TX mapping                       |
|       |             |      |         | 0000: no affect                        |
|       |             |      |         | 0001: map to G1                        |
|       |             |      |         | 0010: map to G2                        |
|       |             |      |         | 0011: map to G3                        |
| 11:8  | UT0TXMAP    | WR   | 0x0     | 0100: map to G4                        |
|       |             |      |         | 0101: map to G5                        |
|       |             |      |         | 0110: map to G6                        |
|       |             |      |         | 0111: map to G7                        |
|       |             |      |         | 1111: Clear these bits                 |
|       |             |      |         | Others is reserved                     |
|       |             | _    |         | SPI0 mapping                           |
| 7.4   | CDIOMAD     | WD   | 0.40    | 0000: no affect                        |
| 7:4   | SPIOMAP     | WR   | 0x0     | 0001: map to G1                        |
|       |             |      |         | 0010: map to G2                        |

| Bit | Name   | Mode | Default | Description            |
|-----|--------|------|---------|------------------------|
|     |        |      |         | 0011: map to G3        |
|     |        |      |         | 1111: Clear these bits |
|     |        |      |         | Others is reserved     |
|     |        |      |         | SD0 mapping            |
|     |        |      |         | 0000: no affect        |
|     |        |      |         | 0001: map to G1        |
|     |        |      |         | 0010: map to G2        |
| 2.0 | SD0MAP | WR   | 0.40    | 0011: map to G3        |
| 3:0 | SDUMAP | VVR  | 0x0     | 0100: map to G4        |
|     |        |      |         | 0101: map to G5        |
|     |        |      |         | 0110: map to G6        |
|     |        |      |         | 1111: Clear these bits |
|     |        |      |         | Others is reserved     |

### Register 3-15FUNCMCON1: Port function mapping control Register 1

| Bit   | Name       | Mode | Default | Description                            |
|-------|------------|------|---------|----------------------------------------|
| 31:28 |            |      |         |                                        |
| 27:24 |            |      |         |                                        |
| 23:20 |            |      |         |                                        |
| 19:16 |            |      |         |                                        |
| 15:12 |            |      |         |                                        |
|       |            |      |         | UART2 RX mapping                       |
|       |            |      |         | 0000: no affect                        |
|       |            |      |         | 0001: map to G1                        |
| 11:8  | UT2RXMAP   | WR   | 0x0     | 0010: map to G2                        |
|       |            |      |         | 0011: map to TX pin by UT2TXMAP select |
|       |            |      |         | 1111: Clear these bits                 |
|       |            |      |         | Others is reserved                     |
|       |            |      |         | UART2 TX mapping                       |
|       |            |      |         | 0000: no affect                        |
| 7:4   | UT2TXMAP   | WR   | 0x0     | 0001: map to G1                        |
| 7:4   | UTZTXIVIAP | VVK  | UXU     | 0010: map to G2                        |
|       |            |      |         | 1111: Clear these bits                 |
|       |            |      |         | Others is reserved                     |
| 3:0   |            |      |         |                                        |

### Register 3-16FUNCMCON2: Port function mapping control Register 2

| Bit   | Name       | Mode | Default | Description                |
|-------|------------|------|---------|----------------------------|
| 31:24 | -          | -    | -       | Unused                     |
| 23:20 |            |      |         |                            |
|       |            |      |         | Timer5 PWM mapping         |
|       |            |      |         | 0000: no affect            |
| 19:16 | TMR5MAP    | WR   | 0x0     | 0001: map to G1            |
|       |            |      |         | 1111: Clear these bits     |
|       |            |      |         | Others is reserved         |
|       |            |      |         | Timer4 PWM mapping         |
|       | TMR4MAP    |      |         | 0000: no affect            |
| 15:12 |            | WR   | 0x0     | 0001: map to G1            |
|       |            |      |         | 1111: Clear these bits     |
|       |            |      |         | Others is reserved         |
|       |            |      |         | Timer3 PWM mapping         |
|       |            |      |         | 0000: no affect            |
| 11:8  | TMR3MAP    | WR   | 0x0     | 0001: map to G1            |
|       |            |      |         | 1111: Clear these bits     |
|       |            |      |         | Others is reserved         |
|       |            |      |         | Timer3 capture Pin mapping |
|       |            |      |         | 0000: no affect            |
| 7:4   | TMR3CPTMAP | WR   | 0x0     | 0001: map to G1            |
|       |            |      |         | 0010: map to G2            |
|       |            |      |         | 0011: map to G3            |

| Bit | Name | Mode | Default | Description            |
|-----|------|------|---------|------------------------|
|     |      |      |         | 0100: map to G4        |
|     |      |      |         | 0101: map to G5        |
|     |      |      |         | 0110: map to G6        |
|     |      |      |         | 0111: map to G7        |
|     |      |      |         | 1111: Clear these bits |
|     |      |      |         | Others is reserved     |
| 3:0 |      |      |         |                        |

# 3.4 External Port interrupt wake up

Support eight wakeup source input, as the following table.

| Wakeup source | Wakeup circuit   |
|---------------|------------------|
| PA7           | Wakeup circuit 0 |
| PB1           | Wakeup circuit 1 |
| PB2           | Wakeup circuit 2 |
| PB3           | Wakeup circuit 3 |
| PB4           | Wakeup circuit 4 |
| WKO           | Wakeup circuit 5 |
| PORT_INT_FALL | Wakeup circuit 6 |
| PORT_INT_RISE | Wakeup circuit 7 |

### Register 3-17WKUPCON: Wake up control Register

| Bit   | Name | Mode | Default | Description                                   |
|-------|------|------|---------|-----------------------------------------------|
| 31:17 | -    | -    | -       | Unused                                        |
| 16    | WKIE | WR   |         | Wake up interrupt enable 0: disable 1: enable |
| 15:8  | -    | -    | -       | Unused                                        |
| 7:0   | WKEN | WR   |         | Wake up input 7~0 enable 0: disable 1: enable |

#### Register 3-18WKUPEDG: Wake up edge select Register

| -0 -  |       |      |         |                                                                     |  |  |  |
|-------|-------|------|---------|---------------------------------------------------------------------|--|--|--|
| Bit   | Name  | Mode | Default | Description                                                         |  |  |  |
| 31:24 | -     | -    | -       | Unused                                                              |  |  |  |
| 23:16 | WKPND | R    | 0x0     | Wake up input 7~0 pending 0: no pending 1: wake up pending          |  |  |  |
| 15:8  | -     | -    | -       | Unused                                                              |  |  |  |
| 7:0   | WKEDG | WR   | 0x0     | Wake up input 7~0 wakeup edge select 0: rising edge 1: falling edge |  |  |  |

### Register 3-19WKUPCPND: Wake up clear pending Register

| Bit   | Name   | Mode | Default | Description                                                           |
|-------|--------|------|---------|-----------------------------------------------------------------------|
| 31:8  | -      | -    | -       | Unused                                                                |
| 23:16 | WKCPND | W    |         | Wake up input 7~0 clear pending 0: no affect 1: clear wake up pending |
| 15:0  | -      | -    | -       | Unused                                                                |

### Register 3-20PORTINTEN: Port interrupt enable Register

| Bit  | Name      | Mode | Default | Description                    |
|------|-----------|------|---------|--------------------------------|
| 31:0 | PORTINTEN | WR   | 0x0     | Port interrupt 0~31 enable bit |
|      |           |      |         | 0: disable                     |

| Bit | Name | Mode | Default | Description |
|-----|------|------|---------|-------------|
|     |      |      |         | 1: enable   |

### Register 3-21PORTINTEDG: Port interrupt edge select Register

| Bit  | Name       | Mode | Default | Description                         |
|------|------------|------|---------|-------------------------------------|
|      |            |      |         | Port interrupt 0~31 edge select bit |
| 31:0 | PORTINTEDG | WR   | 0x0     | 0: rise edge                        |
|      |            |      |         | 1: fall edge                        |

4Timer 15

# 4 Timer

### 4.1 Features

- 1. Timer0/1/2, only support 32bit timer function
- 2. Timer3/4/5, can be configured to Timer-mode, Counter-mode, Capture-mode and PWM-mode

### 4.2 Timer0/1/2 Special Function Registers

### Register 4-1TMR0CON/TMR1CON/TMR2CON: Timer0/1/2 Control Register

| Bit   | Name   | Mode | Default | Description                     |
|-------|--------|------|---------|---------------------------------|
| 31:10 | -      | -    | -       | Unused                          |
|       |        |      |         | Timer overflow pending          |
| 9     | TPND   | WR   | 0       | 0: not overflow                 |
|       |        |      |         | 1: overflow                     |
| 8     | -      | -    | -       | Unused                          |
|       |        |      |         | Timer overflow interrupt enable |
| 7     | TIE    | WR   | 0       | 0: disable                      |
|       |        |      |         | 1: enable                       |
|       |        |      |         | Increase source select          |
| 6     | INCSRC | WR   | 0       | 0: select TMR_INC               |
|       |        |      |         | 1: select external PIN          |
| 5:4   | -      | -    | -       | Unused                          |
|       |        |      |         | Increase clock selection        |
|       |        |      |         | 00: System Clock                |
| 3:2   | INCSEL | WR   | 0x0     | 01: Counter input rising        |
|       |        |      |         | 10: Counter input falling       |
|       |        |      |         | 11: Counter input edge          |
| 1     | -      | -    | -       | Unused                          |
|       |        |      |         | Timer Enable Bit                |
| 0     | TMREN  | WR   | 0       | 0: Disable                      |
|       |        |      |         | 1: Enable                       |

### Register 4-2TMR0CPND/TMR1CPND/TMR2CPND: Timer0/1/2 clear pending Register

| Bit   | Name  | Mode | Default | Description                                                   |
|-------|-------|------|---------|---------------------------------------------------------------|
| 31:16 | -     | -    | -       | Unused                                                        |
| 9     | TPCLR | W    |         | Timer overflow pending clear bit 0: inactive 1: clear pending |
| 8:0   | -     | -    | -       | Unused                                                        |

### Register 4-3TMR0CNT/TMR1CNT/TMR2CNT: Timer0/1/2 counter Register

| Bit  | Name        | Mode | Default | Description                                                                                                                                   |
|------|-------------|------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------|
|      | 31:0 TMRCNT | WR   | 0x0     | Timer counter.                                                                                                                                |
| 31:0 |             |      |         | TMRCNT will increase when timer is enabled. It overflows when TMRCNT = TMRPR, TMRCNT will be clear to 0x0000 when overflow, and the interrupt |
|      |             |      |         | flag will be set '1'.                                                                                                                         |

### Register 4-4TMR0PR/TMR1PR/TMR2PR: Timer0/1/2 period Register

| Bit  | Name  | Mode | Default   | Description              |
|------|-------|------|-----------|--------------------------|
| 31:0 | TMRPR | WR   | 0xfffffff | Timer period = TMRPR + 1 |

4Timer 16

# 4.3 Timer3/4/5 Special Function Registers

Register 4-5TMR3CON/TMR4CON/TMR5CON: Timer3/4/5 Control Register

| Bit   | Name     | Mode | Default | Description                     |
|-------|----------|------|---------|---------------------------------|
| 31:18 | -        | -    | -       | Unused                          |
|       |          |      |         | Timer capture pending           |
| 17    | CPND     | WR   | 0       | 0: not capture                  |
|       |          |      |         | 1: capture                      |
|       |          |      |         | Timer overflow pending          |
| 16    | TPND     | WR   | 0       | 0: not overflow                 |
|       |          |      |         | 1: overflow                     |
| 15:12 | -        | -    | -       | Unused                          |
|       |          |      |         | Timer pwm2 enable bit           |
| 11    | PWM2EN   | WR   | 0       | 0: disable                      |
|       |          |      |         | 1: enable                       |
|       |          |      |         | Timer pwm1 enable bit           |
| 10    | PWM1EN   | WR   | 0       | 0: disable                      |
|       |          |      |         | 1: enable                       |
|       |          |      |         | Timer pwm0 enable bit           |
| 9     | PWM0EN   | WR   | 0       | 0: disable                      |
|       |          |      |         | 1: enable                       |
|       |          |      |         | Timer capture interrupt enable  |
| 8     | CIE      | WR   | 0       | 0: disable                      |
|       |          |      |         | 1: enable                       |
|       |          |      |         | Timer overflow interrupt enable |
| 7     | TIE      | WR   | 0       | 0: disable                      |
|       |          |      |         | 1: enable                       |
|       |          |      |         | Increase source select          |
| 6     | INCSRC   | WR   | 0       | 0: select TMR_INC               |
|       |          |      |         | 1: select external PIN          |
|       |          |      |         | Timer Capture edge select       |
|       |          |      |         | 00: No Capture                  |
| 5:4   | CPTEDSEL | WR   | 0x0     | 01:Capture PIN rising edge      |
|       |          |      |         | 10: Capture PIN falling edge    |
|       |          |      |         | 11: Capture PIN edge            |
|       |          |      |         | Increase clock selection        |
|       |          |      |         | 00: System Clock                |
| 3:2   | INCSEL   | WR   | 0x0     | 01: Counter input rising        |
|       |          |      |         | 10: Counter input falling       |
|       |          |      |         | 11: Counter input edge          |
|       |          |      |         | Timer capture Enable Bit        |
| 1     | CPTEN    | WR   | 0       | 0: Disable                      |
|       |          |      |         | 1: Enable                       |
|       |          |      |         | Timer Enable Bit                |
| 0     | TMREN    | WR   | 0       | 0: Disable                      |
|       |          |      |         | 1: Enable                       |

### Register 4-6TMR3CPND/TMR4CPND/TMR5CPND: Timer3/4/5 clear pending Register

|       |       |      |         | , , , , , , , , , , , , , , , , , , , ,                       |
|-------|-------|------|---------|---------------------------------------------------------------|
| Bit   | Name  | Mode | Default | Description                                                   |
| 31:18 | -     | -    | -       | Unused                                                        |
| 17    | CPCLR | W    | 0       | Capture pending clear bit 0: inactive 1: clear pending        |
| 16    | TPCLR | w    | 0       | Timer overflow pending clear bit 0: inactive 1: clear pending |
| 15:0  | -     | -    | -       | Unused                                                        |

### Register 4-7TMR3CNT/TMR4CNT/TMR5CNT: Timer3/4/5 counter Register

4Timer 17

| Bit  | Name   | Mode | Default | Description                                                                                                                                                                         |
|------|--------|------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TMRCNT | WR   | 0x0     | Timer counter.  TMRCNT will increase when timer is enabled. It overflows when TMRCNT = TMRPR, TMRCNT will be clear to 0x0000 when overflow, and the interrupt flag will be set '1'. |

### Register 4-8TMR3PR/TMR4PR/TMR5PR: Timer3/4/5 period Register

| Bit  | Name  | Mode | Default   | Description              |
|------|-------|------|-----------|--------------------------|
| 31:0 | TMRPR | WR   | 0xfffffff | Timer period = TMRPR + 1 |

### Register 4-9TMR3CPT/TMR4CPT/TMR5CPT: Timer3/4/5 capture value Register

| Bit  | Name   | Mode | Default | Description         |
|------|--------|------|---------|---------------------|
| 31:0 | TMRCPT | R    | х       | Timer capture value |

### Register 4-10TMR3DUTY0/TMR4DUTY0/TMR5DUTY0: Timer3/4/5 pwm0 duty Register

| Bit   | Name     | Mode | Default | Description                                 |
|-------|----------|------|---------|---------------------------------------------|
| 31:16 | -        | -    | -       | Unused                                      |
|       |          |      |         | Timer pwm0 duty                             |
| 15:0  | TMRDUTY0 | W    | х       | PWM0 low level length is TMRDUTY0+1         |
|       |          |      |         | PWM 0 high level length is TMRPR-TMRDUTY0+1 |

### Register 4-11TMR3DUTY1/TMR4DUTY1/TMR5DUTY1: Timer3/4/5 pwm1 duty Register

| Bit   | Name     | Mode | Default | Description                                |
|-------|----------|------|---------|--------------------------------------------|
| 31:16 | -        | -    | -       | Unused                                     |
|       |          |      |         | Timer pwm1 duty                            |
| 15:0  | TMRDUTY1 | W    | х       | PWM1 low level length is TMRDUTY1+1        |
|       |          |      |         | PWM1 high level length is TMRPR-TMRDUTY1+1 |

### Register 4-12TMR3DUTY2/TMR4DUTY2/TMR5DUTY2: Timer3/4/5 pwm2 duty Register

| Bit   | Name       | Mode | Default | Description                                         |
|-------|------------|------|---------|-----------------------------------------------------|
| 31:16 | -          | -    | -       | Unused                                              |
| 15:0  | TMRDUTY2   | W    |         | Timer pwm2 duty PWM2 low level length is TMRDUTY2+1 |
| 13.0  | TIVINDOTTZ | VV   |         | PWM2 high level length is TMRPR-TMRDUTY2+1          |

5PWM 18

# **5 PWM**

### 5.1 Features

Four channel PWM for Breathing-lamp

# 5.2 Special Function Registers

#### Register 5-1 PWMCON: PMW Configure Register

| 1108.51 | Register 5 1 1 William Collingure Register |      |         |                                            |  |  |  |  |
|---------|--------------------------------------------|------|---------|--------------------------------------------|--|--|--|--|
| Bit     | Name                                       | Mode | Default | Description                                |  |  |  |  |
| 31:5    |                                            |      |         |                                            |  |  |  |  |
| E       | PWMIVN                                     | WR   | 0       | PWM invert enable                          |  |  |  |  |
| 5       | PVVIVIIVIN                                 | VVK  | 0       | 0: duty is high level 1: duty is low level |  |  |  |  |
| 4       | AUTOADJUST                                 | WR   | 0       | PWM Auto Adjust enable                     |  |  |  |  |
| 4       | AUTOADJUST                                 | VVK  | 0       | 0: disable 1: enable                       |  |  |  |  |
| 2       | DWMSEN                                     | WD   | 0       | PWM3 enable                                |  |  |  |  |
| 3       | PWM3EN WR                                  | VVK  | 0       | 0: disable 1: enable                       |  |  |  |  |
| 2       | PWM2EN                                     | WD   |         | PWM2 enable                                |  |  |  |  |
| 2       | PVVIVIZEIN                                 | WR   | 0       | 0: disable 1: enable                       |  |  |  |  |
| 4       | PWM1EN                                     | WR   |         | PWM1 enable                                |  |  |  |  |
| ı       | PVVIVITEIN                                 | VVK  | 0       | 0: disable 1: enable                       |  |  |  |  |
| 0       | DWMOEN                                     | WD   |         | PWM0 enable                                |  |  |  |  |
| 0       | PWM0EN                                     | WR   | 0       | 0: disable 1: enable                       |  |  |  |  |

### Register 5-2 PWMPR: PMW period Register

| Bit   | Name  | Mode | Default | Description                      |
|-------|-------|------|---------|----------------------------------|
| 31:16 |       |      |         |                                  |
| 15:0  | PWMPR | WR   | 0xffff  | PWM period = (PWMPR+1) * Tpwmclk |

### Register 5-3 PWM01DUT: PWM0/1 duty registers

| Bit   | Name    | Mode | Default | Description                               |
|-------|---------|------|---------|-------------------------------------------|
| 31:16 | PWM1DUT | WR   | 0x0     | PWM1 duty register; Duty = PWM1DUT/ PWMPR |
| 15:0  | PWM0DUT | WR   | 0x0     | PWM0 duty register; Duty = PWM0DUT/ PWMPR |

### Register 5-4 PWM23DUT: PWM2/3 duty registers

| Bit   | Name    | Mode | Default | Description                               |
|-------|---------|------|---------|-------------------------------------------|
| 31:16 | PWM3DUT | WR   | 0x0     | PWM3 duty register; Duty = PWM3DUT/ PWMPR |
| 15:0  | PWM2DUT | WR   | 0x0     | PWM2 duty register; Duty = PWM2DUT/ PWMPR |

### Register 5-5 PWMCYCNUM: PWM adjust cycle number register

| Bit   | Name       | Mode | Default | Description                                                                                |
|-------|------------|------|---------|--------------------------------------------------------------------------------------------|
| 31:24 | PWM3CYCNUM | WR   | 0x0     | PWM3 Duty adjust cycle num When AUTOADJUST = 1, each PWM3CYCNUM Duty add (PWM3STEP/ PWMPR) |
| 23:16 | PWM2CYCNUM | WR   | 0x0     | PWM2 Duty adjust cycle num When AUTOADJUST = 1, each PWM2CYCNUM Duty add (PWM2STEP/ PWMPR) |
| 15:8  | PWM1CYCNUM | WR   | 0x0     | PWM1 Duty adjust cycle num When AUTOADJUST = 1, each PWM1CYCNUM Duty add (PWM1STEP/ PWMPR) |
| 7:0   | PWM0CYCNUM | WR   | 0x0     | PWM0 Duty adjust cycle num When AUTOADJUST = 1, each PWM0CYCNUM Duty add                   |

5PWM 19

| Bit | Name | Mode | Default | Description       |
|-----|------|------|---------|-------------------|
|     |      |      |         | (PWM0STEP/ PWMPR) |

### Register 5-6 PWMSTEP: PWM Step register

| Bit   | Name     | Mode | Default | Description           |
|-------|----------|------|---------|-----------------------|
| 31:24 | PWM3STEP | WR   | 0x0     | PWM3 Duty adjust step |
| 23:16 | PWM2STEP | WR   | 0x0     | PWM2 Duty adjust step |
| 15:8  | PWM1STEP | WR   | 0x0     | PWM1 Duty adjust step |
| 7:0   | PWM0STEP | WR   | 0x0     | PWM0 Duty adjust step |

# 6 RTC

### 6.1 Features

1. Support 32bit Independent power supply real time counter

2. Support alarm interrupt and second interrupt

# 6.2 Special Function Registers

Register 6-1RTCCON: RTC Control Register

| Bit   | Name       | Mode | Default | Description                                     |
|-------|------------|------|---------|-------------------------------------------------|
| 31:13 | -          | -    | -       | Unused                                          |
|       |            |      |         | VUSB online state                               |
| 20    | VUSBONLINE | R    | О       | 0: not online                                   |
|       |            |      |         | 1: online                                       |
|       |            |      |         | RTC WK pin state                                |
| 19    | RTCWKP     | R    | 0       | 0: WK pin state is 0                            |
|       |            |      |         | 1: WK pin state is 1                            |
|       |            |      |         | RTC 1s pending                                  |
| 18    | RTC1SPND   | R    | 0       | 0: no pending                                   |
|       |            |      |         | 1: 1s pending                                   |
|       |            |      |         | RTC alarm pending                               |
| 17    | ALMPND     | R    | 0       | 0: no pending                                   |
|       |            |      |         | 1: alarm pending                                |
|       |            |      |         | RTC trans done                                  |
| 16    | RTCPND     | R    | 0       | 0: done                                         |
|       |            |      |         | 1:not done                                      |
| 15:9  | -          | -    | -       | Unused                                          |
|       |            |      |         | RTC alarm wakeup enable                         |
| 8     | ALM_WKEN   | WR   | 0       | 0: disable                                      |
|       | _          |      |         | 1: enable                                       |
|       |            |      |         | RTC 1S wakeup enable                            |
| 7     | RTC1S_WKEN | WR   | 0       | 0: disable                                      |
|       |            |      |         | 1: enable                                       |
|       |            |      |         | VUSB insert reset system enable                 |
| 6     | VUSBRSTEN  | WR   | 0       | 0: disable                                      |
|       |            |      |         | 1: enable                                       |
|       |            |      |         | RTC wake up power down mode reset system enable |
| 5     | WKUPRSTEN  | WR   | 0       | 0: disable                                      |
|       |            |      |         | 1: enable                                       |
|       |            |      |         | RTC alarm interrupt enable                      |
| 4     | ALMIE      | WR   | 0       | 0: disable                                      |
|       |            |      |         | 1: enable                                       |
|       |            |      |         | RTC 1S interrupt enable                         |
| 3     | RTC1SIE    | WR   | 0       | 0: disable                                      |
|       |            |      |         | 1: enable                                       |
|       |            |      |         | Increase clock selection                        |
|       |            |      |         | 00: System Clock divide 4                       |
| 2:1   | BAUDSEL    | WR   | 0x0     | 01: System Clock divide 8                       |
|       |            |      |         | 10: System Clock divide 16                      |
|       |            |      |         | 11: System Clock divide 32                      |
| _     | DTOOO      | W.D  |         | RTC cs                                          |
| 0     | RTCCS      | WR   | 0       | 0:disabled                                      |

| Bit | Name | Mode | Default | Description |
|-----|------|------|---------|-------------|
|     |      |      | ·       | 1:enable    |

### Register 6-2RTCDAT: RTC data Register

| Bit   | Name   | Mode | Default | Description       |
|-------|--------|------|---------|-------------------|
| 31:10 | -      | -    | -       | Unused            |
|       |        |      |         | RTC cmd           |
|       |        |      |         | 00: data          |
| 9:8   | RTCMD  | W    | 0x0     | 01: read command  |
|       |        |      |         | 10: write command |
|       |        |      |         | 11: reserve       |
| 7:0   | RTCDAT | WR   | х       | RTC data          |

### Register 6-3RTCCPND: RTC clear pending Register

| Bit   | Name    | Mode | Default | Description                          |
|-------|---------|------|---------|--------------------------------------|
| 31:19 | -       | -    | -       | Unused                               |
| 18    | C1SPND  | R    | 0       | Write 1 will clear RTC 1S pending    |
| 17    | CALMPND | R    | 0       | Write 1 will clear RTC alarm pending |
| 16:0  | -       | -    | -       | Unused                               |

# **6.3 Independent Power RTC Registers**

### Register 6-4 RTCCNT: RTC counter Register

| Bit  | Name   | Mode | Default | Description       |
|------|--------|------|---------|-------------------|
| 31:0 | RTCCNT | WR   | 0x0     | 32bit RTC counter |

### Register 6-5 RTCALM: RTC alarm Register

| Bit  | Name   | Mode | Default   | Description     |
|------|--------|------|-----------|-----------------|
| 31:0 | RTCALM | WR   | 0xfffffff | 32bit RTC alarm |

### Register 6-6 RTCCON0: RTC control Register 0

| Bit | Name     | Mode | Default | Description                             |
|-----|----------|------|---------|-----------------------------------------|
|     |          |      |         | RTC first power up flag                 |
| 7   | PWRUP1ST | WR   | 1       | 0: not first power up                   |
|     |          |      |         | 1: first power up                       |
|     |          |      |         | External 32K select                     |
| 6   | EXT32KS  | WR   | 0       | 0: use RTC internal 32K osc             |
|     |          |      |         | 1: use external 32K osc                 |
| 5   | RSV      | WR   | 1       | Reserve, can't be changed default value |
| 4   | RSV      | WR   | 0       | Reserve, can't be changed default value |
| 3   | RSV      | WR   | 0       | Reserve, can't be changed default value |
| 2   | RSV      | WR   | 0       | Reserve, can't be changed default value |
|     |          |      |         | XOSC32K enable bit                      |
| 1   | X32KEN   | WR   | 0       | 0: disable                              |
|     |          |      |         | 1: enable                               |
| 0   | RSV      | WR   | 0       | Reserve, can't be changed default value |

### Register 6-7 RTCCON1: RTC control Register 1

| Bit | Name   | Mode | Default | Description                                          |
|-----|--------|------|---------|------------------------------------------------------|
| 7   | -      | -    | -       | Unused                                               |
|     |        |      |         | VRTC enable bit, VRTC voltage for ADC                |
| 6   | VRTCEN | WR   | 0       | 0: disable                                           |
|     |        |      |         | 1: enable                                            |
|     |        |      |         | WK pin analog enable bit, output WKO voltage for ADC |
| 5   | WKPAEN | WR   | 0       | 0: disable                                           |
|     |        |      |         | 1: enable                                            |

| Bit | Name    | Mode | Default | Description                     |
|-----|---------|------|---------|---------------------------------|
|     |         |      |         | WK pin pull up enable bit       |
| 4   | WKPPUEN | WR   | 1       | 0: disable                      |
|     |         |      |         | 1: enable                       |
|     |         |      |         | WK pin pull up select bit       |
|     |         |      |         | 00: 80K                         |
| 3:2 | WKPPUS  | WR   | 0x1     | 01: 90K                         |
|     |         |      |         | 10: 100K                        |
|     |         |      |         | 11: 400K                        |
|     |         |      |         | WK pin pull down 10K enable bit |
| 1   | WKPPD   | WR   | 0       | 0: disable                      |
|     |         |      |         | 1: enable                       |
|     |         |      |         | WK pin input enable bit         |
| 0   | WKPIE   | WR   | 1       | 0: disable                      |
|     |         |      |         | 1: enable                       |

### Register 6-8 RTCCON2: RTC control Register 2

|     |          |      | 0       |                                         |
|-----|----------|------|---------|-----------------------------------------|
| Bit | Name     | Mode | Default | Description                             |
|     |          |      |         | 32K osc select bit                      |
| 7   | 32KSEL   | WR   | 0       | 0: 32.768K                              |
|     |          |      |         | 1: 32K                                  |
|     |          |      |         | SEL VDD pullup enable                   |
| 6   | SELVDDPU | WR   | 1       | 0: disable                              |
|     |          |      |         | 1: enable                               |
| 5:4 | RSV      | WR   | 0x0     | Reserve, can't be changed default value |
| 3:2 | RSV      | WR   | 0x2     | Reserve, can't be changed default value |
| 1:0 | RSV      | WR   | 0x2     | Reserve, can't be changed default value |

### Register 6-9 RTCCON3: RTC control Register 3

| Bit | Name       | Mode | Default | Description                      |
|-----|------------|------|---------|----------------------------------|
|     |            |      |         | RTC one second wakeup enable bit |
| 7   | RTC1S_WKEN | WR   | 0       | 0: disable                       |
|     |            |      |         | 1: enable                        |
|     |            |      |         | RTC alarm wakeup enable bit      |
| 6   | ALM_WKEN   | WR   | 0       | 0: disable                       |
|     |            |      |         | 1: enable                        |
|     |            |      |         | VUSB wake up enable bit          |
| 5   | VSUB_WKEN  | WR   | 0       | 0: disable                       |
|     |            |      |         | 1: enable                        |
|     |            |      |         | WK pin wake up enable bit        |
| 4   | WKP_WKEN   | WR   | 0       | 0: disable                       |
|     |            |      |         | 1: enable                        |
| 3   | -          | -    | -       | Unused                           |
|     |            |      |         | VDDCORE enable bit               |
| 2   | VCOREEN    | WR   | 1       | 0: disable                       |
|     |            |      |         | 1: enable                        |
|     |            |      |         | VDDIO enable bit                 |
| 1   | VIOEN      | WR   | 1       | 0: disable                       |
|     |            |      |         | 1: enable                        |
|     |            |      |         | BUCK enable bit                  |
| 0   | BUCKEN     | WR   | 1       | 0: disable                       |
|     |            |      |         | 1: enable                        |

### Register 6-10 RTCCON5: RTC control Register 5

| Bit | Name    | Mode | Default | Description                             |
|-----|---------|------|---------|-----------------------------------------|
| 7   | -       | -    | -       | Unused                                  |
| 6   | RSV     | WR   | 0       | Reserve, can't be changed default value |
| 5:4 | RSV     | WR   | 0x0     | Reserve, can't be changed default value |
| 3:2 | RSV     | WR   | 0x0     | Reserve, can't be changed default value |
| 1   | BUCKLPM | WR   | 0       | BUCK low power mode enable              |

| Bit | Name | Mode | Default | Description              |  |  |  |
|-----|------|------|---------|--------------------------|--|--|--|
|     |      |      |         | 0: disable               |  |  |  |
|     |      |      |         | 1: enable                |  |  |  |
|     |      |      |         | BUCK LDO mode select bit |  |  |  |
| 0   | LDOM | WR   | 1       | 0: buck mode             |  |  |  |
|     |      |      |         | 1: LDO mode              |  |  |  |

### Register 6-11 RTCCON7: RTC control Register 7

| Bit | Name     | Mode | Default | Description                                 |
|-----|----------|------|---------|---------------------------------------------|
| 7:5 | -        | -    | -       | Unused                                      |
| 4   | WKOPRT   | WR   | 0       | WKO protect bit                             |
|     |          |      |         | LVD detect enable after power up by wake up |
| 3   | LVDDETEN | WR   | 0       | 0: disable                                  |
|     |          |      |         | 1:enable                                    |
|     |          |      |         | WK pin filter enable bit                    |
| 2   | WKPFEN   | WR   | 0       | 0: disable                                  |
|     |          |      |         | 1:enable                                    |
|     |          |      |         | WK pin filter select bit                    |
|     |          |      |         | 00:8ms                                      |
| 1:0 | WKPFSEL  | WR   | 0x0     | 01:32ms                                     |
|     |          |      |         | 10:128ms                                    |
|     |          |      |         | 11:512ms                                    |

### Register 6-12 RTCCON8: RTC control Register 8

| Bit | Name     | Mode | Default | Description                |  |  |  |  |
|-----|----------|------|---------|----------------------------|--|--|--|--|
| 7:5 | -        | -    | -       | Unused                     |  |  |  |  |
|     |          |      |         | VUSB wake up pending       |  |  |  |  |
| 4   | VSUBP    | R    | 0       | 0: no pending              |  |  |  |  |
|     |          |      |         | 1: pending                 |  |  |  |  |
|     |          |      |         | WK pin wake up pending     |  |  |  |  |
| 3   | WKP      | R    | 0       | 0: no pending              |  |  |  |  |
|     |          |      |         | 1: pending                 |  |  |  |  |
|     |          |      |         | When write:                |  |  |  |  |
|     |          |      |         | RTC 1 second pending clear |  |  |  |  |
|     |          |      |         | 0: no affect               |  |  |  |  |
| 2   | RTC1SPC  | WR   | 0       | 1: clear 1s pending        |  |  |  |  |
| 2   | KICISFC  | VVIX | U       | When read:                 |  |  |  |  |
|     |          |      |         | RTC 1 second pending       |  |  |  |  |
|     |          |      |         | 0: no second pending       |  |  |  |  |
|     |          |      |         | 1: second pending          |  |  |  |  |
|     |          |      |         | When write:                |  |  |  |  |
|     |          |      |         | RTC alarm pending clear    |  |  |  |  |
|     |          |      |         | 0: no affect               |  |  |  |  |
| 1   | ALMPC    | WR   | 0       | 1: clear alarm pending     |  |  |  |  |
|     |          | VVIX | ľ       | When read:                 |  |  |  |  |
|     |          |      |         | Alarm pending              |  |  |  |  |
|     |          |      |         | 0: no alarm pending        |  |  |  |  |
|     |          |      |         | 1: alarm pending           |  |  |  |  |
|     |          |      |         | When write                 |  |  |  |  |
|     |          |      |         | WK pin 10s pending clear   |  |  |  |  |
|     |          |      |         | 0: no affect               |  |  |  |  |
| 0   | WKP10SC  | WR   | 0       | 1: clear 10s pending       |  |  |  |  |
| O   | WIN 1000 | VVIX | O       | When read:                 |  |  |  |  |
|     |          |      |         | WK pin 10s pending         |  |  |  |  |
|     |          |      |         | 0: no 10s pending          |  |  |  |  |
|     |          |      |         | 1: 10s pending             |  |  |  |  |

### Register 6-13 RTCCON9: RTC control Register 9

| Bit | Name     | Mode | Default | Description             |
|-----|----------|------|---------|-------------------------|
| 7:4 | -        | -    | -       | Unused                  |
| 3:0 | WKP10SEN | W    | 0xa     | WK pin 10s reset enable |

| Bit | Name | Mode | Default | Description                  |  |  |
|-----|------|------|---------|------------------------------|--|--|
|     |      |      |         | 0xa: disable                 |  |  |
|     |      |      |         | Others: enable               |  |  |
|     |      |      |         | After enable, can't disable. |  |  |

7UARTO 25

# 7 **UARTO**

### 7.1 Features

1. UART is a serial port capable of asynchronous transmission.

2. The UART can function in full duplex mode.

# 7.2 UARTO Special Function Registers

Register 7-1UART0CON: UART Control Register

| Bit   | Name      | Mode   | Default | Description                    |
|-------|-----------|--------|---------|--------------------------------|
| 31:10 | -         | -      | -       | Unused                         |
|       |           |        |         | RX pending                     |
| 9     | RXPND     | R      | 0       | 0: RX one byte not finish      |
|       |           |        |         | 1: RX one byte finish          |
|       |           |        |         | TX pending                     |
| 8     | TXPND     | R      | 0       | 0: TX one byte not finish      |
|       |           |        |         | 1: TX one byte finish          |
|       |           |        |         | RX enable                      |
| 7     | RXEN      | WR     | 0       | 0: RX disable                  |
|       |           |        |         | 1: RX enable                   |
|       |           |        |         | One-line mode                  |
| 6     | ONELINE   | WR     | 0       | 0: TX/RX separate              |
|       |           |        |         | 1: TX/RX one line              |
|       | CLKSRC WR |        |         | Clock source select            |
| 5     |           |        | 0       | 0: system clock                |
|       |           |        |         | 1: uart_inc                    |
|       |           |        |         | Two Stop Bit enable            |
| 4     | SB2EN     | 2EN WR |         | 0:1-bit Stop Bit               |
|       |           |        |         | 1: 2 bit Stop Bit              |
|       |           |        |         | Transmit Interrupt Enable      |
| 3     | TXIE      | WR     | 0       | 0 = Transmit interrupt disable |
|       |           |        |         | 1 = Transmit interrupt enable  |
|       |           |        |         | Receive Interrupt Enable       |
| 2     | RXIE      | WR     | 0       | 0: Receiver interrupt disable  |
|       |           |        |         | 1: Receiver interrupt enable   |
|       |           |        |         | BIT9 Enable Bit                |
| 1     | BIT9EN    | WR     | 0       | 0: Eight-bit mode              |
|       |           |        |         | 1: Nine-bit mode               |
|       |           |        |         | UART Enable Bit                |
| 0     | UTEN      | WR     | 0       | 0: Disable UART module         |
|       |           |        |         | 1: Enable UART module          |

### Register 7-2UARTOCPND: UARTO clear pending Register

| Bit   | Name       | Mode | Default | Description                      |  |  |  |
|-------|------------|------|---------|----------------------------------|--|--|--|
| 31:18 | -          | -    | -       | Unused                           |  |  |  |
|       |            |      |         | Reset Key match pending clear    |  |  |  |
| 17    | CRSTKEYPND | W    | 0       | 0: N/A                           |  |  |  |
|       |            |      |         | 1: Clear Reset key match Pending |  |  |  |
|       |            |      |         | Key match pending clear          |  |  |  |
| 16    | CKEYPND    | W    | 0       | 0: N/A                           |  |  |  |
|       |            |      |         | 1: Clear key match Pending       |  |  |  |

7UARTO 26

| Bit   | Name   | Mode | Default | Description                                                 |  |  |  |
|-------|--------|------|---------|-------------------------------------------------------------|--|--|--|
| 15:10 | -      | -    | -       | Unused                                                      |  |  |  |
|       |        |      |         | RX pending clear                                            |  |  |  |
| 9     | CRXPND | W    | 0       | 0: N/A                                                      |  |  |  |
|       |        |      |         | 1: Clear RX Pending                                         |  |  |  |
|       |        | W    | 0       | TX pending clear                                            |  |  |  |
| 8     | CTXPND |      |         | 0: N/A                                                      |  |  |  |
|       |        |      |         | 1: Clear TX Pending. Writing data to UTBUF will clear TXPND |  |  |  |
| 7:0   | -      | -    | -       | Unused                                                      |  |  |  |

### Register 7-3UART0BAUD: UART Baud Rate Register

| Bit               | Name             | Mode | Default | Description                               |  |  |  |
|-------------------|------------------|------|---------|-------------------------------------------|--|--|--|
| 31:16 UARTORXBAUD |                  | ١٨/  | 0       | UART RX Baud Rate                         |  |  |  |
| 31.10             | UARTURADAUD      | W    | U       | Baud Rate =Fsys clock / (UART0RXBAUD + 1) |  |  |  |
| 15:0 UARTO        | 14 DT0T\/D 41 ID | W    | 0       | UART TX Baud Rate                         |  |  |  |
|                   | UART0TXBAUD      |      |         | Baud Rate =Fsys clock / (UART0TXBAUD + 1) |  |  |  |

### Register 7-4 UARTODATA: UART Data Register

| Bit  | Name      | Mode | Default | Description                                                    |  |  |  |
|------|-----------|------|---------|----------------------------------------------------------------|--|--|--|
| 31:9 | -         | -    | -       | Unused                                                         |  |  |  |
| 8    | UART0BIT8 | WR   | х       | UART Data bit 8                                                |  |  |  |
|      |           |      |         | UART Data                                                      |  |  |  |
| 7:0  | UART0DAT  | WR   | х       | Write this register will load the data to transmitter buffer.  |  |  |  |
|      |           |      |         | Read this register will read the data from the receiver buffer |  |  |  |

### 7.3 User Guide

- 1. Set IO in the correct direction.
- 2. Configure UARTOBAUD to choose sample rate
- 3. Enable UARTO by setting
- 4. Set TXIE or RXIE 'to 1' if needed
- 5. write data to UARTODATA
- 6. Wait for PND to change to '1', or wait for interrupt
- 7. Read received data from UARTODATA if needed

8SPI0 27

# 8 **SPIO**

### 8.1 Features

SPIO can support different mode

- 1. general 3 wire mode, 1-bit clock in/out, 1-bit data output, 1-bit data input
- 2. 2 wire mode, 1-bit clock in/out, 1-bit data output or input;
- 3. 2 data bus mode, 1-bit clock in/out, 2-bit data output or input;
- 4. 4 data bus mode, 1-bit clock in/out, 4-bit data output or input;

9Characteristics 28

# 9 Characteristics

### 9.1 PMU Parameters

Table 9-1 PMU voltage input Parameters

| Sym  | Characteristics       | Min | Тур | Max | Unit | Conditions |
|------|-----------------------|-----|-----|-----|------|------------|
| VUSB | Charger Voltage input | 3.0 | 5.0 | 5.0 | V    |            |
| VBAT | Voltage input         | 3.0 | 3.7 | 5.0 | V    |            |

### Table 9-2 3.3V LDO Parameters

| Sym     | Characteristics             | Min | Тур | Max | Unit | Conditions              |
|---------|-----------------------------|-----|-----|-----|------|-------------------------|
| VDDIO   | 3.3V LDO voltage output     | 3.0 | 3.3 | 3.6 | V    | Light Loading condition |
| △VVDDIO | Output Mismatch 1-sigma     | -   | 56  | -   | mV   | VDDIO=3.3v              |
| ILOAD   | Maximum output current      | -   | -   | 150 | mA   | @VBAT=3.6v              |
| ISC     | Short Circuit Current Limit | -   | -   | 300 | mA   | @VBAT=3.8v              |

#### Table 9-3 1.6V LDO Parameters

| Sym     | Characteristics             | Min | Тур | Max | Unit | Conditions              |
|---------|-----------------------------|-----|-----|-----|------|-------------------------|
| VDDBT   | 1.6V LDO voltage output     | -   | 1.6 | -   | V    | Light Loading condition |
| △VVDDBT | Output Mismatch 1-sigma     | -   | 27  | -   | mV   | VDDBT=1.6v              |
| ILOAD   | Maximum output current      | -   | -   | 100 | mA   | @VBAT=3.0v              |
| ISC     | Short Circuit Current Limit | -   | -   | 200 | mA   | @VBAT=3.8v              |

Table 9-4 1.2V LDO Parameters

| Sym       | Characteristics             | Min | Тур | Max | Unit | Conditions              |
|-----------|-----------------------------|-----|-----|-----|------|-------------------------|
| VDDCORE   | 1.2V LDO voltage output     | -   | 1.2 | _   | V    | Light Loading condition |
| △VVDDCORE | Output Mismatch 1-sigma     | -   | 20  | -   | mV   | VDDCORE=1.2v            |
| ILOAD     | Maximum output current      | -   |     | 80  | mA   | @VBAT=3.6v              |
| ISC       | Short Circuit Current Limit | -   | •   | 120 | mA   | @VBAT=3.8v              |

### 9.2 **IO Parameters**

Table 9-5 I/O Parameters

|                                 |                               | •            |      |         |      |       |            |  |  |
|---------------------------------|-------------------------------|--------------|------|---------|------|-------|------------|--|--|
| GPIO—Electrical Characteristics |                               |              |      |         |      |       |            |  |  |
| Symbol                          | Description                   | Related GPIO | Min  | Typical | Max  | Units | Conditions |  |  |
| V <sub>IL</sub>                 | Low-level input voltage       |              | -0.3 |         | 1.27 | V     | VDDIO=3.3V |  |  |
| ViH                             | High-level input voltage      |              | 2.03 |         | 3.6  | V     | VDDIO=3.3V |  |  |
| Driver Ability 1                | Output Driver Ability 1       |              |      | 32      |      | mA    | VDDIO=3.3V |  |  |
| Driver Ability 0                | Output Driver Ability 0       |              |      | 8       |      | mA    | VDDIO=3.3V |  |  |
| R <sub>PUP0</sub>               | Internal pull-up resister 0   |              | 8    | 10      | 12   | ΚΩ    |            |  |  |
| R <sub>PUP1</sub>               | Internal pull-up resister 1   |              | 0.24 | 0.3     | 0.36 | ΚΩ    |            |  |  |
| R <sub>PUP2</sub>               | Internal pull-up resister 2   |              | 160  | 200     | 240  | ΚΩ    |            |  |  |
| R <sub>PDN0</sub>               | Internal pull-down resister 0 |              | 8    | 10      | 12   | ΚΩ    |            |  |  |
| R <sub>PDN1</sub>               | Internal pull-down resister 1 |              | 0.24 | 0.3     | 0.36 | ΚΩ    |            |  |  |
| R <sub>PDN2</sub>               | Internal pull-down resister 2 |              | 160  | 200     | 240  | ΚΩ    |            |  |  |

9Characteristics 29

# 9.3 Audio DAC Parameters

Table 9-6 Audio DAC Parameters

| Sym          | Characteristics        | Min | Тур | Max | Unit                   | Conditions                    |
|--------------|------------------------|-----|-----|-----|------------------------|-------------------------------|
|              |                        |     |     |     |                        | VCM cap=1uF                   |
|              |                        |     |     |     |                        | VDDDAC cap=1uF                |
| SNR          |                        | -   | 96  | -   | dB                     | with A-wt filter              |
|              |                        |     |     |     |                        | Output -3dBV                  |
|              |                        |     |     |     |                        | Fin=1KHz                      |
|              |                        |     |     |     |                        | VCM cap=1uF                   |
|              |                        |     |     |     |                        | VDDDAC cap=1uF                |
| THD+N        |                        | -   | -86 | -   | dB                     | with A-wt filter              |
|              |                        |     |     |     |                        | Output -3dBV with 10K loading |
|              |                        |     |     |     |                        | Fin=1KHz                      |
| Output Range | Maximum output voltage | -   | 2.6 |     | V <sub>peak-peak</sub> | 32ohm Loading                 |

### 9.4 Audio ADC Parameters

Table 9-7 Audio ADC Parameters

| Sym         | Characteristics                | Min | Тур | Max | Unit | Conditions                    |
|-------------|--------------------------------|-----|-----|-----|------|-------------------------------|
|             |                                |     |     |     |      | VCM cap=1uF                   |
|             |                                |     |     |     |      | VDDDAC cap=1uF                |
| SNR         |                                | -   | 90  | -   | dB   | with A-wt filter              |
|             |                                |     |     |     |      | Input sine amplitude, 850mV   |
|             |                                |     |     |     |      | Fin=1KHz                      |
|             |                                |     |     |     |      | VCM cap=1uF                   |
|             |                                |     |     |     |      | VDDDAC cap=1uF                |
| THD+N       |                                | _   | -87 | _   | dB   | with A-wt filter              |
|             |                                |     |     |     | u.b  | Input sine amplitude, 850mV   |
|             |                                |     |     |     |      | RMS                           |
|             |                                |     |     |     |      | Fin=1KHz.                     |
| Input Range | Input sine wave peak amplitude | 0   |     | VCM | V    | From aux input, aux 0db gain, |
|             | ppau                           | -   |     |     | Ī    | VCM represent VCM voltage.    |

### 9.5 BT Parameters

Table 9-8 BT Parameters

| Characteristics             | Min | Typical | Max | Unit | Conditions                    |
|-----------------------------|-----|---------|-----|------|-------------------------------|
| Maximum Transmit Power      | -   | 2       | -   | dBm  |                               |
| RMS DEVM                    | -   | 5.5     | -   | %    |                               |
| Peak DEVM                   | -   | 12.5    |     | %    | Maximum TX power              |
| EDR Relative Transmit Power |     | -0.2    |     | dB   | 2-DH5 packet                  |
| Sensitivity @ Basic Rate    |     | -90.5   |     | dBm  | BER=0.1%, using DH5 packet    |
| Sensitivity @ EDR           |     | -89.5   |     | dBm  | BER=0.01%, using 2-DH5 packet |

9Characteristics 30

# 9.6 Current Parameters

### Table 9-9 Current Parameters

| Sym   | Characteristics  | Min | Тур | Max  | Unit | Conditions             |
|-------|------------------|-----|-----|------|------|------------------------|
| IRTC  | RTC mode current | -   | 4   | -    | uA   | 4.2V input, room temp. |
| Sleep | Sleep current    | -   | 500 | 2000 | uA   | 3.3V input, room temp  |